[id].vue 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147
  1. <template>
  2. <!-- 页面头部 -->
  3. <HomePageHead></HomePageHead>
  4. <!-- 导航栏 -->
  5. <HomePageNavigation1></HomePageNavigation1>
  6. <!-- 列表页广告一 -->
  7. <HomeTopTen :imgurl="adList[0]" v-if="adList[0]"></HomeTopTen>
  8. <!-- 面包屑导航 -->
  9. <div class="breadcrumb">
  10. <div class="inner">
  11. <span class="location">当前位置:</span>
  12. <el-breadcrumb :separator-icon="ArrowRight">
  13. <el-breadcrumb-item :to="{ path: '/' }">首页</el-breadcrumb-item>
  14. <el-breadcrumb-item :to="{ path: `/newsList/${routLevelId}` }">{{ routLevelTitle }}</el-breadcrumb-item>
  15. <el-breadcrumb-item>{{ routeNewsTtitle }}</el-breadcrumb-item>
  16. </el-breadcrumb>
  17. </div>
  18. </div>
  19. <!-- 资讯列表 -->
  20. <div class="newsDetail">
  21. <div class="inner">
  22. <div class="innerLeft">
  23. <div class="LeftTop">
  24. <h1>{{ newsDetail.title }}</h1>
  25. <p>
  26. 来源: <span>{{ newsDetail.copyfrom }}</span>
  27. 作者: <span>{{ newsDetail.author }}</span>
  28. 发布时间: <span>{{ time }}</span>
  29. </p>
  30. <img :src="newsDetail.imgurl" v-if="newsDetail.imgurl">
  31. </div>
  32. <div class="leftBottom" v-html="newsDetail.content" v-if="newsDetail.content"></div>
  33. <!-- 免责声明: -->
  34. <div class="disclaimer" v-if="newsDetail.fromurl">
  35. <p>原文链接:{{ newsDetail.fromurl }}</p>
  36. <p>[免责声明]本文来源于网络转载,仅供学习交流使用,不构成商业目的。 版权归原作者所有,如涉及作品内容,版权和其他问题,请在30日与本网联系,我们将第一时间处理。</p>
  37. </div>
  38. </div>
  39. <div class="innerRight">
  40. <!-- 热点资讯1 -->
  41. <div class="hotList1">
  42. <DetailHotNews></DetailHotNews>
  43. </div>
  44. <!-- 热点资讯2 -->
  45. <div class="hotList2">
  46. <DetailHotNews2></DetailHotNews2>
  47. </div>
  48. </div>
  49. </div>
  50. </div>
  51. <!-- 页面底部 -->
  52. <HomeFoot1></HomeFoot1>
  53. </template>
  54. <script setup>
  55. //1.页面依赖 start ---------------------------------------->
  56. import { onMounted } from 'vue'
  57. import { ElBreadcrumb, ElBreadcrumbItem } from 'element-plus'
  58. import { ArrowRight } from '@element-plus/icons-vue'
  59. const nuxtApp = useNuxtApp();
  60. const axios = nuxtApp.$axios;
  61. //获得跳转过来的id
  62. const route = useRoute();
  63. const articleId = route.params.id; //获得该页面的id
  64. //1.页面依赖 end ---------------------------------------->
  65. //2.页面数据 start ---------------------------------------->
  66. //2.1 资讯详情
  67. const newsDetail = ref({})
  68. const routeNewsTtitle = ref("");
  69. //2.2 发布日期
  70. const time = ref("");
  71. //2.3 路径
  72. const routLevelTitle = ref("");
  73. const routLevelId = ref("");
  74. //2.4获取详情
  75. async function getPageData() {
  76. const { data: mkdata, error: mkdataError } = requestData('/web/selectWebsiteArticleInfo', {
  77. method: 'GET',
  78. query: {
  79. 'articleid': articleId
  80. },
  81. });
  82. if (mkdataError.value) {
  83. //console.log()
  84. } else {
  85. if (mkdata.value) {
  86. console.log(999999)
  87. console.log(mkdata.value.data)
  88. newsDetail.value = mkdata.value.data;
  89. routLevelTitle.value = newsDetail.value.cat_name;
  90. routLevelId.value = newsDetail.value.category_id;
  91. time.value = newsDetail.value.updated_at.split(' ')[0]
  92. if (newsDetail.value.title.length >= 30) {
  93. routeNewsTtitle.value = newsDetail.value.title.substr(0, 30) + "...";
  94. } else {
  95. routeNewsTtitle.value = newsDetail.value.title
  96. }
  97. }
  98. }
  99. }
  100. getPageData();
  101. //2.5 获得广告
  102. let adList = ref([]);
  103. const {data:adData,error:adError} = requestData('/web/getWebsiteAdvertisement',{method:'GET',query:{'ad_tag':'DETAIL'}});
  104. if (adError.value) {
  105. console.error('广告列表请求失败:', adError.value);
  106. } else {
  107. //当有值了以后再放进去,万恶之源,也是nuxt2和3都存在的一个问题,也许nuxt4会解决这个问题
  108. if (adData.value && adData.value.data) {
  109. console.log(6688)
  110. adList.value = adData.value.data;
  111. console.log(adData.value.data)
  112. }
  113. }
  114. //2.页面数据 end ---------------------------------------->
  115. //3.设置seo信息 start---------------------------------------->
  116. //3.1 设置seo信息
  117. const setData = await requestDataPromise('/web/selectWebsiteArticleInfo', {
  118. method: 'GET',
  119. query: {
  120. 'articleid': articleId
  121. },
  122. });
  123. let seoTitle = setData.data.title;
  124. let seoDescription = setData.data.introduce;
  125. let seoKeywords = setData.data.keyword;
  126. useSeoMeta({
  127. title: seoTitle,
  128. meta: [
  129. { name: 'description', content: seoDescription },
  130. { name: 'keywords', content: seoKeywords }
  131. ]
  132. });
  133. //4.设置seo信息 end---------------------------------------->
  134. </script>
  135. <style lang="less" scoped>
  136. @import url('@/assets/css/detail.less');
  137. </style>